
$('.all-sort-list > .item').hover(function(){

    var eq = $('.all-sort-list > .item').index(this),				//获取当前滑过是第几个元素

        h = $('.all-sort-list').offset().top,						//获取当前下拉菜单距离窗口多少像素

        s = $(window).scrollTop(),									//获取游览器滚动了多少高度

        i = $(this).offset().top,									//当前元素滑过距离窗口多少像素

        item = $(this).children('.item-list').height(),				//下拉菜单子类内容容器的高度

        sort = $('.all-sort-list').height();						//父类分类列表容器的高度



    if ( item < sort ){												//如果子类的高度小于父类的高度

        if ( eq == 0 ){

            $(this).children('.item-list').css('top', (i-h));

        } else {

            $(this).children('.item-list').css('top', (i-h)+1);

        }

    } else {

        if ( s > h ) {												//判断子类的显示位置，如果滚动的高度大于所有分类列表容器的高度

            if ( i-s > 0 ){											//则 继续判断当前滑过容器的位置 是否有一半超出窗口一半在窗口内显示的Bug,

                $(this).children('.item-list').css('top', (s-h)+2 );

            } else {

                $(this).children('.item-list').css('top', (s-h)-(-(i-s))+2 );

            }

        } else {

            $(this).children('.item-list').css('top', 3 );

        }

    }



    $(this).addClass('hover');

    $(this).children('.item-list').css('display','block');

},function(){

    $(this).removeClass('hover');

    $(this).children('.item-list').css('display','none');

});



$('.item > .item-list > .close').click(function(){

    $(this).parent().parent().removeClass('hover');

    $(this).parent().hide();

});
